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CROSS REFERENCE TO RELATED APPLICATIONS 

10 This application claims the benefit of U.S. Provisional Application No. 

60/153,004, filed September 9, 2000, the entire contents of which is hereby 
incorporated by reference. 

FIELD OF THE INVENTION 

The present invention relates generally to computer security, and more 
15 particularly, to systems and methods for authenticating a web page. 

BACKGROUND OF THE INVENTION 

Web pages often include icons, such as, corporate logos, patterns, 
characters, symbols or other indicators, that a user associates with a particular 
offering in the real world. A trust or good will is often associated with the 

20 recognition of a given set of icons. These icons are implemented, for example, 
as bitmaps, but unfortunately, these bitmaps can be copied and used to defraud 
a prospective customer. Additionally, customers rely on the accuracy of a URL 
of a web page. However, it is relatively easy for a "fraudster" to register a URL 
that is like the one the user is expecting, but is not quite the same. For example, 

25 "www.bigbank.com" vs. "www.blgbank.com" (with an "I" instead of an "i"). Thus, 
a user may retrieve an unwanted webpage that appears authentic. Therefore, 
the user may not always be confident that the web page being viewed is 
authentic and the true owner of a web page may be uncertain. 
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In addition to a user's lack of confidence in the true owner of a web page, 
there currently exists a problem (either real or perceived) in the transport of 
UserlDs/Passwords across the Internet. While most sites provide security, for 
example by using a secure protocol such as Secure Hypertext Transfer Protocol 
5 (HTTPS) for sensitive data, most consumers are complacent about checking for 
this security. Thus, a need exists for a system and method that allow a page to 
be authenticated so that a user feels secure in the authenticity of pages 
displayed from Internet sites. 

SUMMARY OF THE INVENTION 

10 In exemplary embodiments of the invention, a user requests a web page 

from a web site using a web browser. The web server receives the request, 
retrieves the web page and forwards it to an authentication server. The 
authentication server inserts an authenticity key into the web page, then the page 
(including the authenticity key) is returned to the user. If the page includes an 

15 authenticity key, the authenticity is verified at the user's computer because the 
user computer includes logic (e.g., software) to verify the authenticity. 

In exemplary embodiments, the authenticity verification software is a 
browser piug-in and is configured by the user after it is downloaded to the user's 
computer. During the user configuration process, the user defines an 

20 authenticity stamp which determines the format of an authenticated page. In 
alternative embodiments, the user defines a non-authenticity stamp which will 
appear on non-authenticated pages. 

BRIEF DESCRIPTION OF THE DRAWINGS 

The above and other features and advantages of the present invention are 
25 hereinafter described in the following detailed description of illustrative 

embodiments to be read in conjunction with the accompanying drawing figures, 
wherein like reference numerals are used to identify the same or similar parts in 
the similar views, and: 

Figure 1 is an exemplary web page that has not been authenticated; 
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Figure 2 is the exemplary web page of Figure 1 that has been 
authenticated in accordance with the present invention; 

Figure 3 is the exemplary web page of Figure 1 that has been 
authenticated using an alternative embodiment of the present invention; 
5 Figure 4 is a block diagram of an exemplary system configuration suitable 

for implementing the present invention; 

Figure 5 is a message sequence diagram for performing page 
authentication in accordance with the present invention; 

Figures 6A and 6B are a flow diagram illustrating exemplary logic 
10 performed by a user computer for performing authentication in accordance with 
the present invention; 

Figure 7 is a flow diagram illustrating exemplary logic for loading an 
authentication module in accordance with the present invention; 

Figure 8 is a flow diagram illustrating exemplary logic for verifying 
15 authenticity and displaying an authenticated page in accordance with the present 
invention; 

Figure 9 is a flow diagram illustrating exemplary logic performed by a web 
server for performing authentication in accordance with the present invention; 
Figure 10 is a flow diagram illustrating exemplary logic performed by an 
20 authentication server in accordance with the present invention; and 
Figure 11 is an exemplary authenticity key. 

DETAILED DESCRIPTION OF EXEMPLARY EMBODIMENTS 

The present invention provides for an icon with an additional level of 
functionality that allows a user to validate that current information (e.g., a web 

25 page) originates from the true owner of the icon and is not merely a copy. In 

various exemplary embodiments of the invention, a hierarchy of validations exists 
which allow not only for the validation of an individual icon, but also for the 
validation of screens and Uniform Resource Locators (URLs). Unlike Secure 
Sockets Layer (SSL) or other "security session" protocols, the present invention 

30 validates aspects of the screen display independent of the communications 
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channel between the user and the web site (however, security session protocols 
may be used in addition to the present invention). The validation is performed 
using only information that the true owner of the icon can possess. 

Figure 1 is an example of a simple web page. The web page 50 includes 
5 a title 52, several hyperlinks 54A, 54B, 54C and 54D, some textual 
information 56 and two graphical images 58A and 58B. 

A web page that has been authenticated using the present invention will 
include all of the information in the same format as the non-authenticated page. 
As shown in Figure 2, in addition to the information that would normally be 

10 displayed, an authenticated page includes an authenticity stamp 60 in which the 
user can specify the appearance of the authenticity stamp. For example, the 
user of the example shown in Figure 2 defined the authenticity stamps to be a 
diamond shape which includes text (bold and italicized) that states "JOE'S SEAL 
OF APPROVAL." It will be appreciated that an unlimited number of variations of 

15 an authenticity stamp are possible. A user can configure the stamp to be 
graphics only, text only or a combination thereof. The user also specifies the 
color and other attributes of the stamp, for example, a blinking stamp. The user 
also specifies the location of the stamp, e.g., bottom right corner of the web 
page, pop-up dialog box, etc. In exemplary embodiments, the authenticity stamp 

20 can be audio instead of or in addition to visual. In alternative embodiments, a 
non-authenticated page is stamped and an authenticated page is not stamped. 
For example, the stamp is configured to be a red, flashing icon that reads "PAGE 
NOT AUTHENTICATED" in the upper right-hand corner, while a page that is 
authenticated does not include this stamp. In alternative examples, the user can 

25 define both an authenticity stamp and a non-authenticity stamp. 

Figure 3 illustrates an alternative embodiment wherein each graphical 
image includes an embedded authenticity stamp 62A and 62B. In the example 
illustrated in Figure 3, each graphical element has an authenticity stamp 
containing the text "A-OKAY" embedded in the graphical image. In exemplary 

30 embodiments, the authenticity stamp is defined by the user. In other 

embodiments, the authenticity stamp is defined by the owner of the page being 
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displayed (e.g., the web server). In such embodiments, the stamp can include 
the name of the trusted entity (i.e., the true owner of the page). 

Figure 4 is a block diagram of an exemplary environment 100 suitable for 
implementing the present invention. The system 100 includes one or more 
5 clients (e.g., users) 1 10 that communicate with one or more servers (e.g., web 
servers) 120. The users 110 can use any type of computing device that includes 
a display device, for example, a Personal Computer. It will be appreciated that 
other computing devices can be used, for example, a Personal Digital Assistant 
(PDA), a hand-held computing device, a cellular telephone, etc. The web server 

10 can be any site, for example a commercial web site, such as a merchant site, a 
government site, an educational site, etc. The user 110 establishes a connection 
to the web server 120 via a network 130, such as the Internet. The user 110 and 
web server 120 can communicate using a secure protocol (e.g., HTTPS) or a 
non-secure protocol (e.g., HTTP). The user 110 requests information from the 

15 web server 120, and in exemplary embodiments, the information is 

communicated using web pages, for example using HyperText Markup Language 
(HTML). The web pages are displayed on the user's computer 1 1 0, for example, 
using a browser, such as, Netscape Communicator available from the Netscape 
Corporation of Mountain View, California or Internet Explorer available from the 

20 Microsoft Corporation of Redmond, Washington. Prior to sending the requested 
web page to user 110, web server 120 submits the information to authentication 
server 140 where authenticating information is added. The information which 
includes the authenticating information is returned to the web server 120 which 
then sends the web page including the authentication information to the 

25 user 110. 

In various exemplary embodiments, the authentication server 140 
communicates with a security engine 150, for example to verify UserlD/Password 
logons or single use passwords or identifiers. In exemplary embodiments, the 
security engine 150 is a commercially available security engine, such a, 
30 Siteminder available from Netegrity Corporation, of Waltham, Massachusetts. 
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The examples illustrated and described herein are directed to exemplary 
embodiments in which a user utilizes a web browser to request web pages from 
a web server. However, it will be appreciated that various embodiments are 
possible wherein a client (e.g., web browser) requests content (e.g., a web page) 
5 from a server (e.g., a web server). The present invention allows the server to 
provide the client with assurance as to the authenticity of the content (e.g., 
assure the client as to the true owner of the content). 

Figure 5 is a message sequence diagram illustrating exemplary 
communications among various components to assure a user of the authenticity 
10 of a page. User 1 1 0 includes a web browser 1 1 2 and a plug-in 1 1 4. A user 
requests a page 180, but the user (e.g., user computer) 110 has no knowledge 
that the page requested is "special" (e.g., is subject to page authentication). 
Thus, the page request 180 is a normal page request (e.g., a HTTP or HTTPS 
request for a page). 

15 The web server 120 receiving the page request 180 determines whether 

the request is for an authenticated page. If the page is to be authenticated, the 
page is dynamically signed with a private key and additional information, such as 
a salt with a time stamp is also included as described in further detail later. The 
signed page is returned with a special authenticated page MIME type and 

20 returned to the web browser 112. Based on the MIME type, the web browser 
activates the appropriate plug-in 114. 

The plug-in 114 uses a public key to verify the signature, and upon 
verification of the signature, the plug-in can validate the authenticity of the page. 
The plug-in 114 requests the user's preferences key 186 so that the page can be 

25 displayed with an authenticity stamp. In exemplary embodiments, the request for 
preferences key includes a shared secret and is encrypted with the public key 
and salt. Upon receipt of the request for preferences key 1 86, the web 
server 120 decrypts the request using the private key, validates the shared 
secret and encrypts the preferences key with the private key, shared secret and 

30 salt from the request 186. The encrypted preferences key is then returned to the 
plug-in 114. 
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The plug-in 114 reads the preferences file and decrypts it using the 
preferences key from the web server 120. In exemplary embodiments, the 
preferences file is stored on the user's 1 10 file system. However, the location of 
the file is not readily known to the plug-in 1 14. Thus, the plug-in 114 must get 
5 the preferences key to determine the location of the preferences file. The 
plug-in 114 reads the preferences file to determine the authenticity stamp and 
how it is to be displayed. The page is then displayed with the user's preferred 
authenticity stamp 1 90. 

Figures 6A-10 illustrate exemplary logic for performing page 

10 authentication in accordance with the present invention. The flow diagrams 

illustrate in further detail the logic illustrated in the message sequence diagram of 
Figure 5. In addition to authenticating a page, the present invention provides for 
additional security wherein a User ID/Password are encrypted with the public key 
to prevent "man in the middle" attacks. Figures 6A-8 illustrate exemplary logic 

15 performed by a user computer 1 1 0 as described below. Figure 9 illustrates 
exemplary logic performed by a web server 120 as described below. Figure 10 
illustrates exemplary logic performed by an authentication server 140 as 
described below. It will be appreciated that various configurations are possible. 
For example, the logic of the authentication server 140 can be combined with the 

20 logic of the web server 1 20. 

Figures 6A and 6B are a flow diagram illustrating exemplary logic 
performed by a user 1 10 for performing authentication in accordance with the 
present invention. The logic described herein is directed to web pages, however 
it will be appreciated that the information requested can be of various formats. 

25 The logic of Figure 6A moves from a start block to block 200 to wait for a page 
request. It will be appreciated that a page request is known in the art, for 
example, a user enters a Uniform Resource Locator (URL) or clicks on a 
hyperlink. The logic then moves to block 201 where a received page request is 
sent to a web Server 120 to retrieve the requested page. The logic then moves 

30 to block 202 where the user (e.g., the user's browser) waits for the requested 
page. The logic of retrieving and formatting the requested page is described 
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below with reference to Figures 9 and 10. When the requested page is 
received, the logic moves to block 204 where the page is read. 

After a page is read, the logic moves to decision block 205 where a test is 
made to determine if a UserlD/Password is required. It will be appreciated that a 
5 UserlD/Password may be required for both pages requiring authentication and 
pages not requiring authentication. If a UserlD/Password is required, the logic 
moves to block 206 where a UserlD/Password is obtained. If a UserlD/Password 
is required, a suitable logon screen is displayed on the user's computer. The 
UserlD/Password entry display can be of varying formats, for example, a web 

10 page or a pop-up dialog box. Upon entry of a UserlD/Password, the user 
indicates completion (for example, by pressing an "OK" or "Submit" button). 
Upon completion of the logon, the logic moves to block 207 where the 
UserlD/Password is encrypted to prevent man in the middle attacks. The logic 
then moves to block 208 where the encrypted UserlD/Password is sent to the 

15 Webserver. 

If a UserlD/Password is not required, the logic moves to decision 
block 209 (Figure 6B) where a test is made to determine if authentication is 
required. In exemplary embodiments, an authenticity key will be hidden in any 
page that should be authenticated. In order to determine if the page should be 

20 authenticated, the page source is read to determine if an authenticity key is 
included in the page. If authentication is not required, the logic moves to 
block 210 where the non-authenticated page is displayed. A non-authenticated 
page is a traditional web page (i.e., the way the web page would be displayed 
without the authentication of the present invention, such as the example shown in 

25 Figure 1). 

If authentication is required (yes in decision block 209), the logic moves to 
decision block 211 where a test is made to determine if the authentication 
module is loaded. In exemplary embodiments, the authentication module is a 
plug-in module for the web browser. In exemplary embodiments, if the 
30 authentication module has not been loaded, a message will be displayed. For 
example, "This page protected by AuthentiPage, to get a free copy, go to 
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Authentipage.com." Alternatively, the message may ask the user if a download 
of the authentication module is desired. If the authentication module is not 
loaded, the logic moves to decision block 214 where a test is made to determine 
if the authentication module should be loaded. If the authentication module is not 
5 to be loaded, the logic moves to block 218 where the page is displayed without 
authentication. In exemplary embodiments, the user will be notified that the page 
could not be authenticated, for example via a pop-up window displaying a 
warning message. In alternative embodiments, the user defines a non- 
authenticity stamp which is displayed for a page that has not been authenticated. 

10 If the authentication module is to be loaded (yes in decision block 214), 

the logic moves to block 216 where the authentication module is loaded as 
shown in Figure 7 and described next. If a download of the authentication 
module is desired, the user may be automatically redirected to the download site. 
Figure 7 illustrates exemplary logic for loading an authentication module 

15 (block 216 of Figure 6B). The logic of Figure 7 moves from a start block to 
block 300 where the authentication module (e.g., plug-in) is downloaded. The 
download is accomplished using techniques known in the art. After the 
authentication module is downloaded to the user's computer, the logic moves to 
block 302 where the authentication module is configured. As part of the 

20 configuration process, an authenticity stamp is defined by the user. This 

authenticity stamp will be displayed whenever an authenticated page is loaded. 
The stamp can take several forms, for example, a user-selected keyword, color, 
etc. Preferably, the determination of the look of the authenticity stamp is under 
complete control of the user. Preferably, the user is also able to determine 

25 where the stamp will be displayed, for example in a separate pop-up box or in a 
selected area of the web page. By requiring the user to configure the visual 
qualities of the stamp, the possibility of a counterfeit stamp being displayed is 
reduced. The user will expect to see his or her stamp and will begin to associate 
the stamp with security. It will be appreciated that while the stamp is defined in 

30 terms of visual qualities herein, embodiments of the invention can include 

defining the stamp in other ways, for example, by an audio indication specified by 
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the user. After the authentication module has been configured, the logic of 
Figure 7 ends and processing returns to Figure 6B. 

Returning to Figure 6B, after the authentication module is loaded 
(block-216), or if it has been determined that the authentication module is already 
5 loaded (yes in decision block 21 1), the logic moves to block 212 to verify the 
authenticity of the page and display the page, as shown in detail in Figure 8 and 
described next. 

Figure 8 illustrates exemplary logic for verifying the authenticity of a page 
and displaying the page. The logic of Figure 8 moves from a start block to 

10 block 400 where the authenticity of the page is verified. Many algorithms can be 
used to verify the authenticity. For example, the trusted server that generates 
the authenticity key can encrypt the authenticity key with a private key. The user 
can then decrypt the authenticity key using a public key. Using this method, no 
certificate is required and no interaction is required by the user. Other algorithms 

15 can be used, some of which may require a certificate and/or user interaction. 
Unless the page contains confidential information, the authentication of pages 
should not require any additional security or encryption. The authentication of a 
page can be employed on any page, for example, marketing data, purchase 
information, etc., to prove the page's authenticity. In general, authentication of 

20 pages will not require additional security or encryption. However, if additional 
security is desired, page authentication performed in accordance with the present 
invention can be used in combination with other known or future security 
measures, for example, in conjunction with a secure protocol, such as HTTPS, 
along with the requirement for a UserlD and a password, etc. If the 

25 authentication is successful (yes in decision block 402), the logic moves to 

block 404 where the page is displayed with the authenticity stamp as defined by 
the user during the configuration process described above. If the authentication 
fails (no in decision block 402), the logic moves to block 406 where the 
unsuccessfully authenticated page is displayed. In exemplary embodiments, an 

30 indication of the authentication failure is provided, for example a warning 

message may be displayed. For example, a flashing error message, such as 
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"PAGE NOT AUTHENTICATED" can be displayed in the location where the 
authenticity stamp would normally be displayed. After the page is displayed 
(either as an authenticated page in block 404 or as an unsuccessfully 
authenticated page in block 406), the logic of Figure 8 ends and processing 
5 returns to Figure 6B. 

Returning to Figure 6B, after a page has been displayed (block 210, 212 
or 218) or a UserlD/Password request has been processed, the logic moves to 
decision block 220 (Figure 6A) where a test is made to determine if it is time to 
exit. For example, if the user selects an "Exit" option form a web browser menu, 

10 it is time to exit. If it is not time to exit, the logic returns to block 200 to wait for 
the user's next page request. The logic of blocks 200-220 is repeated until it is 
time to exit. It will be appreciated that in alternative embodiments of the 
invention requests other than those shown and described herein may also be 
processed. When it is time to exit, the logic of Figure 6A ends. 

15 Figure 9 is a flow diagram illustrating exemplary logic performed by a web 

server 120 for performing authentication in accordance with the present 
invention. The logic of Figure 9 moves from a start block to block 500 where the 
web server waits for a request. In exemplary embodiments, while the web server 
is waiting for a request other requests continue to be serviced (e.g., receiving 

20 and processing page requests). When a request is received, the logic moves to 
decision block 501 where a test is made to determine if the request is a request 
for validation of a UserlD/Password. If so, the logic moves to block 502 where 
the received UserlD/Password (sent in block 108 of Figure 6A) is forwarded to 
the authentication server 140. 

25 If the request is not a request for verification of a UserlD/Password, the 

logic moves to decision block 504 where a test is made to determine if the 
request is a page request. If so, the logic moves to block 505 where the page 
request is read. The logic then moves to block 506 where the requested page is 
retrieved. Next, the logic moves to block 507 where the requested page is 

30 forwarded to an authentication server 140. The logic then moves to block 508 
where the web server waits for the authenticated page to be returned from the 
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authentication server. In exemplary embodiments, while the web server is 
waiting for an authenticated page, other processing can be performed, for 
example, page requests can be received and processed. When an authenticated 
page is received, the logic moves to block 510 where the authenticated page is 
5 returned to the user that requested the page. 

If the request is not a request to verify a UserlD/Password (no in decision 
block 501) or a page request (no in decision block 504), the request is another 
request, which is processed in block 512. Other requests which may be 
processed by a web Server are not described herein. 

10 After the request (e.g., request for verification of UserlD/Password, page 

request or other request) has been processed, the logic moves to decision 
block 514 where a test is made to determine if it is time to exit. The logic of 
blocks 500-514 is repeated until it is time to exit (e.g., shut down the web server). 
When it is time to exit, the logic of Figure 9 ends. 

15 Figure 10 is a flow diagram illustrating exemplary logic performed by an 

authentication server 140 for performing authentication in accordance with the 
present invention. The logic of Figure 10 moves from a start block to block 600 
where the authentication server waits for an authentication request. When an 
authentication request is received, the logic moves to decision block 601 to 

20 determine if the request is a request to decrypt a UserlD/Password. If so, the 
logic moves to block 602 where the UserlD/Password is decrypted. The logic 
then moves to block 604 where the decrypted UserlD/Password is forwarded to a 
security engine for verification. In exemplary embodiments, the security engine 
is an existing security engine, such as a DSS Security Engine. The Security 

25 Engine verifies the UserlD/Password and forwards the verification as 

appropriate. For example, if the UserlD is not valid, a message will be displayed 
on the user's computer. Because security engines are known in the art, the logic 
employed by the security engine is not discussed further herein. 

If the request is not a request to decrypt a UserlD/Password, the logic 

30 moves to decision block 606 where a test is made to determine if the request is 
an authentication request. If so, the logic moves to block 608 where the 
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authentication server generates an authenticity key. Details for an exemplary 
authenticity key are described below. The logic of Figure 10 then moves to 
block 610 where the authenticity key is inserted into the web page. An exemplary 
authenticity key is shown in Figure 12. Next, the logic moves to block 612 where 
5 the page which includes the authenticity key is returned to the web server. 

While the exemplary embodiments only include processing of requests for 
encryption/decryption or authenticating a page, it will be appreciated that 
alternative embodiments may process other requests. After a request is 
processed (e.g., a UserlD/Password is decrypted or a page is authenticated), the 
10 logic moves to decision block 616 where a test is made to determine if it is time, 
to exit. The logic of blocks 600-616 is repeated until it is time to exit (e.g., shut 
down the authentication server). When it is time to exit, the logic of Figure 10 
ends. 

In alternative embodiments, there is no authentication server. Rather, 

15 graphical images include a hidden identifier identifying the true owner, as well as 
a cryptographic signature to ensure that the graphical image cannot be tampered 
with by a counterfeiter. In various embodiments, the identification is a portion of 
a URL that is encrypted, such as "bigbank.com". Those skilled in the art will 
recognize this as a second-level domain name. Upon receipt of the web page, 

20 the authentication module residing on the user's computer compares the 

identification in the page with the URL from which the web page was fetched. If 
the identification matches, the web page was served by its true owner. If the 
identifications do not match, the user is provided with an indication that the URL 
is not the true owner of the graphical images. For example, a "counterfeit" site 

25 may look just like the site that it was intended to look like because the 

counterfeiter can copy the page, including the graphical images. However, if the 
graphical images include a hidden identifier, the user can be notified that the 
page is "counterfeit." 

An exemplary authenticity key is constructed in such a way that 

30 "freshness" can be determined, for example using a date/time stamp. The 

authenticity key will also include other identifying information as described later. 
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An exemplary authenticity key contains one or more hidden signature objects. In 
exemplary embodiments, the hidden signature object is a value that is the 
encoding of the following fields: web page hash, action, date/time, key identifier 
and digital signature. In exemplary embodiments, the web page hash is 
5 generating using SHA-1 on the entire web page excluding this hidden signature 
object. The Secure Hash Algorithm (SHA) was developed by the National 
Institute of Standards and Technology (NIST) and is specified in the Secure 
Hash Standard (SHS, FIPS 180). SHA-1 is a revision to SHA that was published 
in 1994. SHA-1 is also described in the ANSI X9.30 (part 2) standard. The 

10 algorithm takes a message of greater than 264 bits in length and produces a 
1 60-bit message digest. 

The action is a value used to specify the action to be performed by the 
browser plug-in that verifies this page. Preferably, if the user computer does not 
have the browser plug-in installed, the user will be informed of the required plug- 

15 in. Preferably, the user can elect to download the plug-in at the time the web 
page is received, in which case the web page can be displayed immediately after 
installing the plug-in. In exemplary embodiments if the user elects not to install 
the plug-in, the web page is displayed and the user is provided with an indication 
(e.g., a warning message displayed in a pop-up window) that the page was not 

20 authenticated. Actions are specified in a bit-wise manner so that multiple actions 
can be specified. For example, the action value may be defined to both display 
the security object (e.g., to display a bitmapped image) and to request a secure 
login. 

The date/time field is used to specify the current date and time that the 
25 web page was delivered from the web server. This value is used by the browser 
plug-in to verify that the page is "fresh" (e.g., is not being replayed by a rogue 
site). The present invention may include a synchronization feature which allows 
the user's computer to synchronize its internal clock with atomic clocks available 
over the Internet. This would provide additional security by allowing a more 
30 precise verification of the date/time stamp. 
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The key identifier is used to identify the public key used to verify the 
signature. In exemplary embodiments, a digital signature is used as a salt value 
concatenated with an SHA-1 hash of the other four fields (web page hash, action, 
date/time and key identifier) that has been encrypted using the private key of the 
5 web Page server. A "salt value" is an arbitrary random value that constantly 
changes in order to minimize the possibility of various attacks. 

In exemplary embodiments of the present invention, four keys are used in 
the web page authentication process: a private key, a public key, a master 
encryption key and a preferences encryption key. A private key (of the web page 

10 server) is used to create the "digital signature" within the web page signature. A 
digital signature is generally defined to include a certificate. For the purposes of 
the present invention, exemplary embodiments do not include a certificate. It will 
be appreciated that various embodiments can include a certificate in the digital 
signature. The private key is only distributed to applications requiring its use. A 

15 public key is buried in multiple pieces throughout the browser plug-in. The public 
key is used to verify the Digital Signature within the web Page signature. 
Although the public key itself can be distributed, its storage location should 
remain as obscure as possible to reduce the possibility of attacks. The master 
encryption key is also buried in multiple places in the browser plug-in. The 

20 master encryption key is used to encrypt the preferences encryption key that is 
stored on the user's computer. The preferences encryption key that is stored on 
the user's computer is used to encrypt preferences (e.g., user configuration 
information, such as appearance and location of authenticity stamp) that are 
stored on the user's computer. 

25 When the action indicates a Login, the browser plug-in's user display is 

displayed on the user's computer display with the secure word that will request 
the UserlD and Password. These two values will be prefixed with the salt value 
and date/time information from the web page signature and encrypted using the 
public key. This information will then be sent by the plug-in performing the 

30 Submit. Preferably, the Submit explicitly references the URL to which the 
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information is to be sent. This will allow the information only to be sent to the 
destination that was previously signed within the web Page signature. 

The preferences file is used to store information, such as a user's secure 
word. Preferably, the preferences file is placed in a random directory to help 

5 obscure the location of the preference file and facilitate the creation of unique 
user configurations. This increases the difficulty in creating a general purpose 
rogue program for extracting preferences and keys. 

In exemplary embodiments, new keys are implemented through 
redistribution of the browser plug-in. The new plug-in can contain both the old 

10 and new keys to facilitate implementation of the new keys on a particular date. 

In exemplary embodiments of the invention, the authentication module 
may contain a list of all known UserlDs. The list of known UserlDs can be 
displayed so that the user can select a desired UserlD. Upon selection of a 
UserlD, the user is prompted to enter a password. The UserlD and password 

15 are encrypted with the use of the public key to authenticate the authenticity key. 
The entire string (e.g., [UserlD][Password][original salt value]) is sent to the 
trusted server for verification. The trusted server 120 then extracts the UserlD 
and password and forwards them to the authentication server 140 for verification. 
Exemplary embodiments allow a user to check the validity of their 

20 authentication module. A server allows the authentication module to send a 

request for self-verification. In various embodiments, the validation is performed 
in response to a user request In exemplary embodiments, the authentication 
module includes a suitable user interface which allows a user to request self- 
verification. The authentication module generates a random number ("salt") and 

25 encrypts it with the public key. The value is then sent to a known URL (e.g., a 
URL that is hard-coded in the authentication module). When the authentication 
module receives the request, it is decrypted using the private key and adding an 
additional salt value which is then returned to the client module (user). The client 
module decrypts the response received from the authentication module. The 

30 random values are then compared (without the additional salt added by the 
authentication module). If the value matches the value originally sent, the self- 
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verification is successful. A verification result is displayed to the user to indicate 
whether the verification was successful. 

The present invention may be described herein in terms of functional block 
components, screen shots, optional selections and various processing steps. It 
5 should be appreciated that such functional blocks may be realized by any 
number of hardware and/or software components configured to perform the 
specified functions. For example, the present invention may employ various 
integrated circuit components, e.g., memory elements, processing elements, 
logic elements, look-up tables, and the like, which may carry out a variety of 

10 functions under the control of one or more microprocessors or other control 
devices. Similarly, the software elements of the present invention may be 
implemented with any programming or scripting language such as C, C++, Java, 
COBOL, assembler, PERL, or the like, with the various algorithms being 
implemented with any combination of data structures, objects, processes, 

15 routines or other programming elements. Further, it should be noted that the 
present invention may employ any number of conventional techniques for data 
transmission, signaling, data processing, network control, and the like. For a 
basic introduction of cryptography, please review a text written by Bruce 
Schneider which is entitled "Applied Cryptography: Protocols, Algorithms, And 

20 Source Code In C," published by John Wiley & Sons (second edition, 1996), 
which is hereby incorporated by reference. 

It should be appreciated that the particular implementations shown and 
described herein are illustrative of the invention and its best mode and are not 
intended to otherwise limit the scope of the present invention in any way. 

25 Indeed, for the sake of brevity, conventional data networking, application 

development and other functional aspects of the systems (and components of 
the individual operating components of the systems) may not be described in 
detail herein. Furthermore, the connecting lines shown in the various figures 
contained herein are intended to represent exemplary functional relationships 

30 and/or physical couplings between the various elements. It should be noted that 
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many alternative or additional functional relationships or physical connections 
may be present in a practical electronic transaction system. 

To simplify the description of the exemplary embodiments, the invention is 
frequently described as pertaining to an authentication system. It will be 
5 appreciated, however, that many applications of the present invention could be 
formulated. One skilled in the art will appreciate that the network may include any 
system for exchanging data or transacting business, such as the Internet, an 
intranet, an extranet, WAN, LAN, satellite communications, and/or the like. The 
users may interact with the system via any input device such as a keyboard, 

10 mouse, kiosk, personal digital assistant, handheld computer (e.g., Palm Pilot®), 
cellular phone and/or the like. Similarly, the invention could be used in 
conjunction with any type of personal computer, network computer, workstation, 
minicomputer, mainframe, or the like running any operating system such as any 
version of Windows, Windows NT, Windows2000, Windows 98, Windows 95, 

15 MacOS, OS/2, BeOS, Linux, UNIX, or the like. Moreover, although the invention 
is frequently described herein as being implemented with TCP/IP 
communications protocols, it will be readily understood that the invention could 
also be implemented using IPX, Appletalk, IP-6, NetBIOS, OSI or any number of 
existing or future protocols. Moreover, while the exemplary embodiment will be 

20 described as an authentication system, the system contemplates the use, sale or 
distribution of any goods, services or information over any network having similar 
functionality described herein. 

The customer and merchant may represent individual people, entities, or 
business. The bank may represent other types of card issuing institutions, such 

25 as credit card companies, card sponsoring companies, or third party issuers 

under contract with financial institutions. It is further noted that other participants 
may be involved in some phases of the transaction, such as an intermediary 
settlement institution, but these participants are not shown. 

Each participant is equipped with a computing system to facilitate online 

30 commerce transactions. The customer has a computing unit in the form of a 
personal computer, although other types of computing units may be used 
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including laptops, notebooks, hand held computers, set-top boxes, and the like. 
The merchant has a computing unit implemented in the form of a computer- 
server, although other implementations are possible. The bank has a computing 
center shown as a main frame computer. However, the bank computing center 
5 may be implemented in other forms, such as a mini-computer, a PC server, a 
network set of computers, and the like. 

The computing units are connected with each other via a data 
communication network. The network is a public network and assumed to be 
insecure and open to eavesdroppers. In the illustrated implementation, the 

10 network is embodied as the internet. In this context, the computers may or may 
not be connected to the internet at all times. For instance, the customer 
computer may employ a modem to occasionally connect to the internet, whereas 
the bank computing center might maintain a permanent connection to the 
internet. It is noted that the network may be implemented as other types of 

15 networks, such as an interactive television (ITV) network. 

Any merchant computer and bank computer are interconnected via a 
second network, referred to as a payment network. The payment network 
represents existing proprietary networks that presently accommodate 
transactions for credit cards, debit cards, and other types of financial/banking 

20 cards. The payment network is a closed network that is assumed to be secure 
from eavesdroppers. Examples of the payment network include the American 
Express®, VisaNet® and the Veriphone® network. In an exemplary 
embodiment, the electronic commerce system is implemented at the customer 
and issuing bank. In an exemplary implementation, the electronic commerce 

25 system is implemented as computer software modules loaded onto the customer 
computer and the banking computing center. The merchant computer does not 
require any additional software to participate in the online commerce transactions 
supported by the online commerce system. 

The corresponding structures, materials, acts and equivalents of all 

30 elements in the claims below are intended to include any structure, material or 
acts for performing the functions in combination with other claimed elements as 
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specifically claimed. The scope of the invention should be determined by the 
allowed claims and their legal equivalents, rather than by the examples given 
above. 
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CLAIMS 

What is claimed is: 



1 1 . A method for authenticating data, the method comprising: 

2 a. receiving a data request from a client; 

3 b. retrieving data based on the received data request; 

4 c. formatting the retrieved data, wherein the formatted data includes 

5 at least one authenticity key; and 

6 d. returning the formatted data to the client. 

2. The method of Claim 1 , wherein the formatted data is a web page. 

1 3. The method of Claim 1 , further comprising: 

2 a. reading the formatted data at the client; 

3 b. determining if the formatted data includes the at least one 

4 authenticity key; 

5 c. if the formatted data includes the at least one authenticity key; 

6 d. verifying authenticity based on the at least one authenticity key. 

4. The method of Claim 3, further comprising displaying the data based on 
the verification of the at least one authenticity key. 

5. The method of Claim 4, wherein one authenticity stamp will be displayed 
for data that has been successfully verified. 

6. The method of Claim 4, wherein one authenticity stamp will be displayed 
for each graphical image. 

7. The method of Claim 4, wherein a non-authenticity stamp will be displayed 
for data that has not successfully been verified. 

1 8. A system for authenticating data, the system comprising: 

2 a. at least one client; 
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3 b. at least one server; 

4 c. a network, wherein the client and the server communicate via the 

5 network; and 

6 d. at least one authentication server, wherein said at least one 

7 authentication server is in communication with said at least one 

8 server. 

9. The system of Claim 8, wherein said at least one client includes a 
browser, wherein pages are displayed to a user on a display device on 
said at least one client. 

10. The system of Claim 8, wherein said at least one server sends a page 
including an authenticity key to said at least one client. 



11. The system of Claim 10, wherein said at least one client verifies 
authenticity of the page based on the authenticity key. 

12. The system of Claim 11, wherein the page is displayed on said client, 
wherein the display includes an indication of the authenticity of the page. 



1 13. A system for authenticating data, the system comprising: 

2 a. at least one client; 

3 b. at least one server, wherein said at least one server sends a page, 

4 wherein the page includes at least one graphic image and wherein 

5 each of said at least one graphic images includes an authenticity 

6 key; and, 

7 c. a network, wherein the client and the server communicate via the 

8 network. 

1 14. In a computer system for authenticating data, a computer-readable 

2 medium holding computer executable instructions for performing a method 

3 comprising the steps of: 
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4 a. receiving a data request from a client; 

5 b. retrieving data based on the received data request; 

6 c. formatting the retrieved data, wherein the formatted data includes 

7 an authenticity key; and 

8 d. returning the formatted data to the client. 

15. The computer system of Claim 14, wherein the formatted data is a web 
page. 

1 16. The computer system of Claim 14, wherein computer executable 

2 instructions further comprise the steps of: 

3 a. reading the formatted data at the client; 

4 b. determining if the formatted data includes the authenticity key; 

5 c. if the formatted data includes the authenticity key; 

6 d. verifying authenticity based on the authenticity key. 

17. The computer system of Claim 16, wherein the computer executable 



instructions further comprise the step of: displaying the data based on the 
verification of the authenticity. 

18. The computer system of Claim 17, wherein an authenticity stamp will be 
displayed for data that has been successfully verified. 

19. The computer system of Claim 17, wherein a non-authenticity stamp will 
be displayed for data that has not successfully been verified. 
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ABSTRACT 

The present invention provides for an icon with an additional level of 
functionality that allows a user to validate that current information (e.g., a web 

5 page) originates from the true owner of the icon and is not merely a copy. The 
method includes a user requesting a web page from a web site using a web 
browser. The web server receives the request, retrieves the web page and 
forwards it to an authentication server. The authentication server inserts an 
authenticity key into the web page, then the page (including the authenticity key) 

10 is returned to the user. If the page includes an authenticity key, the authenticity 
is verified at the user's computer because the user computer includes logic (e.g., 
software) to verify the authenticity. During the user configuration process, the 
user defines an authenticity stamp which determines the format of an 
authenticated page. 
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